/*------------------------------------------
common
------------------------------------------*/
body {
  width: 100%;
  background: #fff;
  min-width: 960px;
  height: 100%;
  font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif !important; }

p, div {
  line-height: 1.9; }

img {
  vertical-align: top; }

/*------------------------------------------
header
------------------------------------------*/
#tophead {
  width: 100%;
  margin: 0 auto;
  background: #fff;
  height: 90px;
  border-right: 1px solid #f5f5f5;
  position: fixed;
  display: block;
  z-index: 1000; }
  #tophead h1 {
    width: 154px;
    height: 39px;
    float: left;
    padding-top: 25px; }
  #tophead nav {
    float: right; }
    #tophead nav ul {
      list-style: none; }
      #tophead nav ul .box {
        float: left;
        width: 164px;
        height: 90px;
        display: block;
        position: relative;
        text-align: center;
        border-left: 1px solid #f5f5f5; }
        #tophead nav ul .box a {
          text-decoration: none;
          color: #474747;
          font-size: 15px;
          font-weight: bold;
          background: #fff;
          line-height: 90px;
          display: block;
          background: #ffffff; }
        #tophead nav ul .box a:hover {
          background: #f6f6f6;
          -webkit-transition: all 0.9s;
          -moz-transition: all 0.9s;
          -o-transition: all 0.9s;
          transition: all 0.9s; }
        #tophead nav ul .box .bdT {
          position: absolute;
          width: 0;
          height: 4px;
          top: 0;
          left: 0;
          background: #d91820;
          -webkit-transition: all 0.2s;
          -moz-transition: all 0.2s;
          -o-transition: all 0.2s;
          transition: all 0.2s; }
      #tophead nav ul .box:hover .bdT {
        width: 100%; }

#topheadarea {
  width: 960px;
  margin: auto; }

/*------------------------------------------
MV
------------------------------------------*/
#mv {
  width: 100%;
  height: 600px; }

.particles {
  margin: 0 auto;
  background: #00238C;
  position: relative; }
  .particles h2 {
    width: 277px;
    height: 72px;
    position: absolute;
    top: 240px;
    left: 50%;
    margin-left: -160px; }
  .particles p {
    color: #fff;
    width: 580px;
    text-align: center;
    position: absolute;
    top: 350px;
    left: 50%;
    margin-left: -290px;
    font-size: 0.95em;
    line-height: 1.9; }

/*------------------------------------------
SERVICE
------------------------------------------*/
#service {
  width: 100%; }
  #service header {
    width: 100%;
    height: 135px;
    background: #231815;
    color: #fff;
    text-align: center;
    font-weight: bold; }
    #service header h2 {
      font-size: 40px;
      padding-top: 40px;
      line-height: 40px;
      padding-bottom: 8px; }
    #service header span {
      font-size: 15px; }

#service-contents {
  width: 100%;
  background: #ffffff;
  padding-top: 60px;
  height: 100%;
  padding-bottom: 30px;
  }
  #service-contents #plan01 {
    width: 960px;
    border: 4px #c99509 solid;
    margin: 0 auto;
    height: 100%;
    background: #fff;
    position: relative; }
    #service-contents #plan01 #plan01l {
      width: 411px;
      height: 344px;
      position: absolute;
      top: 50%;
      left: 20px;
      margin-top: -142px; }
    #service-contents #plan01 #plan01r {
      width: 480px;
      height: 100%;
      min-height: 344px;
      background: #c99509;
      position: relative;
      color: #c99509; }
    #service-contents #plan01 #plan01r:after {
      border-top: 62px solid transparent;
      border-right: 26px solid #c99509;
      border-bottom: 62px solid transparent;
      border-left: 26px solid transparent;
      left: -52px;
      content: "";
      display: block;
      top: 50%;
      margin-top: -62px;
      position: absolute;
      width: 0; }
  #service-contents #plan02 {
    width: 960px;
    border: 4px #429138 solid;
    margin: 0 auto 80px;
    height: 100%;
    background: #fff;
    position: relative; }
    #service-contents #plan02 #plan02r {
      width: 414px;
      height: 294px;
      position: absolute;
      top: 50%;
      right: 0;
      margin-top: -140px;
      padding-right: 40px; }
    #service-contents #plan02 #plan02l {
      width: 480px;
      height: 100%;
      min-height: 344px;
      background: #429138;
      color: #429138;
      position: relative; }
    #service-contents #plan02 #plan02l:after {
      border-top: 62px solid transparent;
      border-right: 26px solid transparent;
      border-bottom: 62px solid transparent;
      border-left: 26px solid #429138;
      right: -52px;
      content: "";
      display: block;
      top: 50%;
      margin-top: -62px;
      position: absolute;
      width: 0; }

.plantxtarea {
  width: 400px;
  margin: 0 auto;
  padding: 75px 0 65px; }

.plantitle {
  font-size: 30px;
  font-weight: bold;
  background: #fff;
  text-align: center;
  padding: 20px 0 15px; }

.plantoptxt {
  font-size: 22px;
  font-weight: bold;
  color: #231815;
  text-align: center;
  line-height: 1.5; }

.plantendtxt {
  color: #231815;
  text-align: center;
  line-height: 1.7;
  font-size: 0.95em;
  }

.planbottomtxt {
  font-size: 18px;
  padding-left: 1em;
  text-indent: -1em;
  line-height: 1.3;
  color: #fff; }
  .planbottomtxt ul {
    list-style: none; }
    .planbottomtxt ul li {
      padding-top: 10px; }

.business_list {
    max-width: 960px;
    margin: 65px auto 0;
    display: flex;
    justify-content: space-between;
    flex-flow: row wrap;
}

.business_list_inner {
    width: 30%;
    background-color: #f5f5f5;
    position: relative;
    margin-bottom: 40px;
}

.business_list_inner img {
    width: 100%;
}

.business_list_inner article {
    padding: 0;
    text-align: center;
    position: absolute;
    top: -19px;
    left: -20px;
}

.color1 {
    background-color: #c5651a;
    color: #FFF;
    padding: 10px 10px 10px 10px;
    position: relative;
}

.color2 {
    background-color: #276c9a;
    color: #FFF;
    padding: 10px 10px 10px 10px;
    position: relative;
}

.color3 {
    background-color: #891f89;
    color: #FFF;
    padding: 10px 10px 10px 10px;
    position: relative;
}

.color4 {
    background-color: #429138;
    color: #FFF;
    padding: 10px 10px 10px 10px;
    position: relative;
}

.color5 {
    background-color: #c9950a;
    color: #FFF;
    padding: 10px 10px 10px 10px;
    position: relative;
}

.color6 {
    background-color: #c1191f;
    color: #FFF;
    padding: 10px 10px 10px 10px;
    position: relative;
}



.business_list_inner article p {
    line-height: 40px;
}

/*------------------------------------------
COMPANY
------------------------------------------*/
#company {
  background: #ccc;
  padding-top: 60px;
  padding-bottom: 80px;
  background-size: cover;
  background-attachment: fixed;
  background-repeat: no-repeat;
  background-image: url(../images/bg-company.jpg);
  width: 100%;
  background-position: center; }
  #company header {
    background: none;
    height: 100px;
    width: 100%;
    text-align: center;
    font-weight: bold; }
    #company header h2 {
      font-size: 40px;
      padding-bottom: 8px;
      color: #231815; }
    #company header span {
      font-size: 15px; }

#companyarea {
  width: 960px;
  margin: 0 auto;
  padding: 10px;
  background-color: rgba(255, 255, 255, 0.3); }
  #companyarea table {
    width: 960px;
    border-collapse: collapse; }
    #companyarea table th {
      width: 230px;
      color: #fff;
      text-align: center;
      padding: 20px 0;
      font-size: 15px;
      font-weight: bold; }
    #companyarea table td {
      text-align: left;
      color: #333;
      padding: 15px 0 15px 70px;
      font-size: 15px;
      font-weight: bold;
      line-height: 30px;
      }
    #companyarea table .thbg01 {
      background: #be040d; }
    #companyarea table .thbg02 {
      background: #b6040d; }
    #companyarea table .tdbg01 {
      background: #f9f9f9; }
    #companyarea table .tdbg02 {
      background: #f2f2f2; }

/*------------------------------------------
CONTACT
------------------------------------------*/
#contact {
  width: 100%;
  position: relative;
  height: 184px; }
  #contact #contactarea {
    width: 960px;
    position: absolute;
    top: 60px;
    left: 50%;
    margin-left: -480px;
    display: flex;
    justify-content: space-between;
    }
    #contact #contactarea #contactbox {
      display: block;
      width: 49%;
      height: 58px;
      position: relative;
      }
      #contact #contactarea #contactbox .contacttxt {
        font-size: 20px;
        font-weight: bold;
        text-align: center;
        line-height: 58px;
        color: #fff;
        width: 49%;
        height: 60px;
        text-decoration: none;
        margin: 0 auto;
        display: block;
        }
    #contact #contactarea #contactbox2 {
      display: block;
      width: 49%;
      height: 58px;
      position: relative;
      }
      #contact #contactarea #contactbox2 .contacttxt {
        font-size: 20px;
        font-weight: bold;
        text-align: center;
        line-height: 58px;
        color: #fff;
        width: 49%;
        height: 60px;
        text-decoration: none;
        margin: 0 auto;
        display: block;
        }
      #contact #contactarea #contactbox2 .contacttxt2 {
        font-size: 20px;
        font-weight: bold;
        text-align: center;
        line-height: 58px;
        color: #fff;
        width: 49%;
        height: 60px;
        text-decoration: none;
        margin: 0 auto;
        display: block;
        }
    #contact #contactarea .contacttxt:before {
      content: url(../images/icon-mail.png);
      width: 34px;
      height: 24px;
      position: relative;
      top: 6px;
      right: 6px; }

    #contact #contactarea .contacttxt2:before {
      content: url(../images/icon-tel.png);
      width: 34px;
      height: 24px;
      position: relative;
      top: 6px;
      right: 6px; }

.contactline div {
  background: #fff;
  position: absolute;
  -webkit-transition: all 0.2s;
  -moz-transition: all 0.2s;
  -o-transition: all 0.2s;
  transition: all 0.2s; }

.bdTT {
  width: 100%;
  height: 1px;
  top: 0;
  left: 0; }

.bdBB {
  width: 100%;
  height: 1px;
  bottom: 0;
  right: 0; }

.bdRR {
  height: 100%;
  width: 1px;
  right: 0;
  top: 0; }

.bdLL {
  height: 100%;
  width: 1px;
  left: 0;
  bottom: 0; }

#contactbox:hover .bdTT {
  height: 3px; }
#contactbox:hover .bdBB {
  height: 3px; }
#contactbox:hover .bdRR {
  width: 3px; }
#contactbox:hover .bdLL {
  width: 3px; }

#contactbox2:hover .bdTT {
  height: 3px; }
#contactbox2:hover .bdBB {
  height: 3px; }
#contactbox2:hover .bdRR {
  width: 3px; }
#contactbox2:hover .bdLL {
  width: 3px; }

/*------------------------------------------
FOOTER
------------------------------------------*/
footer {
  width: 100%;
  background: #231815;
  height: 90px; }
  footer p {
    font-size: 12px;
    font-weight: bold;
    color: #fff;
    text-align: center;
    padding-top: 39px; }

@media screen and (max-width: 1024px) {
.business_list {
    max-width: 93%;
}
}

@media screen and (max-width: 640px) {
  .box .bdT {
    display: none; }
 }
